package exercise;

class Solution2 {
    public void duplicateZeros(int[] arr) {
        // 先找到最后一个要复写的数
        int dest = -1;
        int cur = -1;
        while (dest < arr.length-1) {
            cur++;
            if (arr[cur] == 0) {
                dest += 2;
            } else {
                dest++;
            }
        }

        // 处理边界情况
        if (dest == arr.length) {
            dest--;
            arr[dest--] = 0;
            cur--;
        }

        // 复写
        while (cur >= 0) {
            if (arr[cur] == 0) {
                arr[dest--] = 0;
                arr[dest--] = 0;
                cur--;
            } else {
                arr[dest--] = arr[cur--];
            }
        }
    }
}